Coverage Report

Created: 2024-12-19 06:34

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
D:\a\tools.proto\tools.proto\compiler\src\gen\base\message_from_bytes.rs
Line
Count
Source
1
// Copyright (c) 2024, BlockProject 3D
2
//
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without modification,
6
// are permitted provided that the following conditions are met:
7
//
8
//     * Redistributions of source code must retain the above copyright notice,
9
//       this list of conditions and the following disclaimer.
10
//     * Redistributions in binary form must reproduce the above copyright notice,
11
//       this list of conditions and the following disclaimer in the documentation
12
//       and/or other materials provided with the distribution.
13
//     * Neither the name of BlockProject 3D nor the names of its contributors
14
//       may be used to endorse or promote products derived from this software
15
//       without specific prior written permission.
16
//
17
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
21
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29
use crate::compiler::message::{Field, Message};
30
use crate::compiler::util::types::TypeMapper;
31
use crate::gen::base::map::TypePathMapper;
32
use crate::gen::base::message::{Templates, Utilities};
33
use crate::gen::base::message_common::generate_field_type_inline;
34
use crate::gen::base::Error;
35
use itertools::Itertools;
36
37
55
fn gen_field_from_bytes_impl<U: Utilities, T: TypeMapper>(
38
55
    field: &Field,
39
55
    templates: &Templates,
40
55
    type_path_map: &TypePathMapper<T>,
41
55
    function: &str,
42
55
) -> Result<String, Error> {
43
55
    let mut scope = templates.template.scope();
44
55
    scope.var("name", &field.name);
45
55
    let codec_template = templates.get(field.codec())
?0
;
46
55
    let msg_type = generate_field_type_inline::<U, T>(field, codec_template, type_path_map, "from_bytes")
?0
;
47
55
    if let Some(
header6
) = &field.header {
  Branch (47:12): [True: 6, False: 49]
  Branch (47:12): [True: 0, False: 0]
  Branch (47:12): [Folded - Ignored]
48
6
        scope.var("header_name", &header.name);
49
49
    }
50
55
    scope.var("type", msg_type);
51
55
    if field.header.is_some() && 
field.ty.is_union()6
{
  Branch (51:8): [True: 6, False: 49]
  Branch (51:34): [True: 4, False: 2]
  Branch (51:8): [True: 0, False: 0]
  Branch (51:34): [True: 0, False: 0]
  Branch (51:8): [Folded - Ignored]
  Branch (51:34): [Folded - Ignored]
52
4
        Ok(scope.render(function, &["field_union"]).unwrap())
53
51
    } else if field.header.is_some() {
  Branch (53:15): [True: 2, False: 49]
  Branch (53:15): [True: 0, False: 0]
  Branch (53:15): [Folded - Ignored]
54
2
        Ok(scope.render(function, &["field_header"]).unwrap())
55
49
    } else if field.ty.is_message_reference() {
  Branch (55:15): [True: 3, False: 46]
  Branch (55:15): [True: 0, False: 0]
  Branch (55:15): [Folded - Ignored]
56
3
        Ok(scope.render(function, &["field_msg"]).unwrap())
57
    } else {
58
46
        Ok(scope.render(function, &["field"]).unwrap())
59
    }
60
55
}
61
62
30
pub fn generate_from_bytes_impl<U: Utilities, T: TypeMapper>(
63
30
    msg: &Message,
64
30
    templates: &Templates,
65
30
    type_path_map: &TypePathMapper<T>,
66
30
    function: &str,
67
30
) -> Result<String, Error> {
68
30
    let fields = msg
69
30
        .fields
70
30
        .iter()
71
55
        .map(|field| gen_field_from_bytes_impl::<U, T>(field, templates, type_path_map, function))
72
30
        .collect::<Result<Vec<String>, Error>>()
?0
73
30
        .join("");
74
30
    let field_names = msg
75
30
        .fields
76
30
        .iter()
77
55
        .map(|field| templates.template.scope().var("name", &field.name).render(function, &["field_name"]).unwrap())
78
30
        .join("");
79
30
    Ok(templates
80
30
        .template
81
30
        .scope()
82
30
        .var("fields", fields)
83
30
        .var("field_names", field_names)
84
30
        .render("", &[function])
85
30
        .unwrap())
86
30
}
87
88
28
pub fn generate<'variable, U: Utilities, T: TypeMapper>(
89
28
    mut templates: Templates<'_, 'variable>,
90
28
    msg: &'variable Message,
91
28
    type_path_map: &TypePathMapper<T>,
92
28
    function: &str,
93
28
) -> Result<String, Error> {
94
28
    templates.template.var("msg_name", &msg.name);
95
28
    generate_from_bytes_impl::<U, T>(msg, &templates, type_path_map, function)
96
28
}